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Foreword 

This Technical Specification has been produced by the 3"* Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 
where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 

Introduction 

The present document is part 12 of a multi-part TS covering the 3'^'' Generation Partnership Project: Technical 
Specification Group Core Network; Open Service Access (OSA); Application Programming Interface (API), as 
identified below. The API specification (3GPP TS 29.198) is structured in the following Parts: 



Part 1: Overview 

Part 2: Common Data Definitions 

Part 3: Framework 

Part 4: Call Control SCF 

Part 5: User Interaction SCF 

Part 6: Mobility SCF 

Part 7: Terminal Capabilities SCF 

Part 8: Data Session Conti'ol SCF 

Part 9: Generic Messaging SCF 

Part 10: Connectivity Manager SCF 

Part 11: Account Management SCF 

Part 12: Cliarging SCF 

The Mapping specification of the OSA APIs and network protocols (3GPP TR 29.998) is also structured as above. 
A mapping to network protocols is however not applicable for all Parts, but the numbering of Parts is kept. 
Also in case a Part is not supported in a Release, the numbering of the parts is maintained. 



(not part of 3GPP Release 4) 
(not part of 3GPP Release 4) 



^^ OSA API specifications 29.198-faiiiily 


OSA API Mapping - 29.998-faniily | 


29.198-1 


Part 1: Overview 


29.998-1 


Part 1: Overview 


29.198-2 


Part 2: Coimnon Data Definitions 


29.998-2 


Not Applicable 


29.198-3 


Part 3: Framework 


29.998-3 


Not Applicable 


29.198-4 


Part 4: Call Control SCF 


29.998-4-1 


Subpart 1: Generic Call Control - CAP mapping 


29.998-4-2 




29.198-5 


Part 5: User Interaction SCF 


29.998-5-1 


Subpart 1: User Interaction - CAP mapping 


29.998-5-2 




29.998-5-3 




29.998-5-4 


Subpart 4: User Interaction - SMS mapping 


29.198-6 


Part 6: Mobility SCF 


29.998-6 


User Status and User Location - MAP mapping 


29.198-7 


Part 7: Terminal Capabilities SCF 


29.998-7 


Not Applicable 


29.198-8 


Part 8: Data Session Control SCF 


29.998-8 


Data Session Control - CAP mapping 


29.198-9 


Part 9: Generic Messaging SCF 


29.998-9 


Not Applicable 


29.198-10 


Part 10: Connectivity Manager SCF 


29.998-10 


Not Applicable 


29.198-11 


Part 11: Account Management SCF 


29.998-11 


Not Applicable 


29.198-12 


Part 12: Charging SCF 


29.998-12 


Not Applicable 
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1 Scope 



The present document is Part 12 of the Stage 3 specification for an Application Programming Interface (API) for Open 
Service Access (OS A). 

The OS A specifications define an architecture that enables application developers to make use of network functionality 
through an open standardised interface, i.e. the OSA APIs. The concepts and the functional architecture for the OSA are 
contained in 3GPP TS 23.127 [3]. The requirements for OSA are contained in 3GPP TS 22.127 [2]. 

The present document specifies the Charging Service Capability Feature (SCF) aspects of the interface. All aspects of 
the Charging SCF are defined here, these being; 

Sequence Diagrams 

Class Diagrams 

Interface specification plus detailed method descriptions 

State Transition diagrams 

Data definitions 

IDL Description of the interfaces 

The process by which this task is accomplished is through the use of object modelling techniques described by the 
Unified Modelling Language (UML). 

This specification has been defined jointly between 3GPP TSG CN WG5, ETSI SPAN 12 and the Parlay Consortium, 
in co-operation with the JAIN consortium. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TS 29.198-1 "Open Service Access; Application Programming Interface; Part 1: 

Overview" . 

[2] 3GPP TS 22.127: "Stage 1 Service Requirement for the Open Service Access (OSA) (Release 4)". 

[3] 3GPP TS 23.127: "Virtual Home Environment (Release 4)". 

[4] World Wide Web Consortium Composite Capability/Preference Profiles (CC/PP): A user side 

framework for content negotiation (www.w3.org). 

[5] Wireless Application Protocol (WAP), Version 1.2, UAProf Specification ( www.wapforum.org ). 

[6] ISO 4217 (1995): "Codes for the representation of currencies and funds". 



£75/ 



3GPP TS 29.198-12 version 4.0.0 Release 4 6 ETSI TS 129 198-12 V4.0.0 (2001-06) 

3 Definitions and abbreviations 

3.1 Definitions 

For the purposes of the present document, the terms and definitions given in TS 29.198-1 [1] apply. 

3.2 Abbreviations 

For the purposes of the present document, the abbreviations given in TS 29.198-1 [1] apply. 

4 Ciiarging SCF 

The following clauses describe each aspect of the Charging Service Capability Feature (SCF). 
The order is as follows: 

• The Sequence diagrams give the reader a practical idea of how each of the SCF is implemented. 

• The Class relationships clause show how each of the interfaces applicable to the SCF, relate to one another 

• The Interface specification clause describes in detail each of the interfaces shown within the Class diagram part. 

• The State Transition Diagrams (STD) show the transition between states in the SCF. The states and transitions are 
well-defmed; either methods specified in the Interface specification or events occurring in the underlying networks 
cause state transitions. 

• The Data definitions section show a detailed expansion of each of the data types associated with the methods within 
the classes. Note that some data types are used in other methods and classes and are therefore defined within the 
Common Data types part of this specification. 



5 Sequence Diagrams 

5.1 Reservation / payment in parts 

The sequence diagram illustrates how to request a reservation and how to charge a user from the reserved amount, for 
instance to charge a user for a streamed video which lasts 10 minutes and costs a total of $2.00. The operations and 
interfaces that do not provide rating are employed throughout this sequence diagram. 

We assume the application has already discovered the Charging SCF. As a result, the application received an object 
reference pointing to an object that implements the IpChargingManager interface. 

1. The application creates a local object implementing the IpAppChargingSession interface. This object will receive 
response messages from the IpChargingSession object. 

2. The application opens a charging session, a reference to a new or existing object implementing IpChargingSession is 
returned together with a unique session ID. 

3. In this case a new object is used. 

4. The application requests the reservation of $2.00. 

5. Assuming the criteria for requesting a reservation are met (the application provider has permission to charge the 
requested amount, the charged user has agreed to pay the requested amount), the amount is reserved in the session. At 
this point, the application provider knows that the network operator will accept later debit requests up to the reserved 
amount. So, the application may start serving the user, for instance by sending the video stream. 

6. The successful reservation is reported back to the application. 
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After half of the video has been sent to the user, the appHcation may choose to capture half of the price already: 

7. The application requests to debit $1.00 from the reservation. 

8. The successful debit is reported back to the application. 

9. The acknowledge is forwarded to the application. 

10. The application checks if the remaining lifetime of the reservation will cover the remaining 5 minutes of video. Let 
us assume, it does not. 

11. The application asks the IpChargingSession object to extend the lifetime of the reservation. 

12. Assuming that the application provider is allowed to keep reservations open for longer than 10 minutes, the 
extendLifeTimeReqO will be honoured and confirmed properly. 

13. The confirmation is forwarded to the application. 

14. When the complete video has been transmitted to the user without errors, the application charges another $1.00. 

15. The IpChargingSession object acknowledges the successful debit at the IpAppChargingSession callback object. 

16. The IpAppChargingSession object forwards the acknowledge to the application. 

17. Since the service is complete, the application frees all resources associated with the reservation and session. 

The operations which handle units are used exactly the same, except that the amount of application usage is indicated 
instead of a price. 
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Application 



bAppCliargingSession _;_ : IpCliargingSession 

pCharginglVlanager 



1 : new() 



2: createChargingSession () 



<r 



6: forward event() 



^ 



4: reserveAmountReqO 



3: newQ 



<r 



5: reserveAmountResQ 



^ 



9: forward event() 



7: debitAmountReqO 



<^ 



8: debitAmountResO 



^ 



13: forward event() 



lOigetLifeTimeLeftO 



1 1 : extendLifeTimeReqO 



12: extendLifeilmeResO 



^ 



14: debitAmountReqO 



15: debitAmo|jntRes() 



^ 



16: forward event() 



^ 



17: releaseO 



^ 



-^ 



-^ 



^ 



-^ 



-^ 



"^ 
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5.2 Immediate Charge 



This sequence diagram illustrates how immediate charging is used. Assume a WAP gateway that charges the user $0.01 
per requested URL. Since it is acceptable to loose one tick worth $0.01, no prior reservations are made. The WAP 
gateway sends an immediate debit for each requested URL, and should a payment have as result failure, the user is 
disconnected. 

1. The application creates a local object implementing the IpAppChargingSession interface. This object will receive 
response messages from the IpChargingAmountSession object. 

2. The application orders the creation of a session. No new object is created for the charging session handling in this 
example implementation. 

3. The application requests to charge the user $0.01. 

4. The payment is acknowledged. 

5. The acknowledgement is forwarded in the application. 

6. The application requests to charge the user $0.01. 

7. The payment is reported to fail. 

8. The failure report is forwarded in the application. 

(repeat steps 3-5 and 6 - 8 as long as you want to in any order you want to) 

9. The application releases the session 

The operations which handle units are used exactly the same, except that the amount of application usage is indicated 
instead of a price. 
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Application 



ipAppCharginqSession 



>3CharginqlVlanager 



IpChargingSession 



1 : newO 



2: createChai'gingSession () 



3: debitAmountReqO 



5: forward notification 



4: debitAm(;)untRes() 



^ 



^ 



6: debitAmountReqO 



7: debitArriountErr() 



8: forward notification n^ 



9: releaseQ 



£75/ 



3GPP TS 29.198-12 version 4.0.0 Release 4 



11 



ETSI TS 129 198-12 V4.0.0 (2001-06) 



Class Diagrams 



This class diagram shows the appUcation interfaces for charging and their relations to the service interfaces. 



IpChargingSession 

(from cs) 



[ *creditAmountReq() 
{ *=reditUnitReq() 

%JebitAmountReq() 

*debitUnitReq() 
! %JirectCreditAmountR... 
i %JirectCreditUnitReq() 
1 %JirectDebitAmountRe.. 

%JirectDebitUnitReq() 

■^xtendLifeTimeReqO 
^ ^etAmountLeftO 

^getLifeTimeLeftO 
. '^getUnitLeftO 
■ %ateReq() 

^eleaseO 

%eserveAmountReq() 
I ^eserveUnitReqO 



0..ni 



IpChargingManager 

(from cs) 

IcreateChargingSessi. 



Iplriterfac 

e -- 

(fronCciafit 



IpAppCharging Session 
(from cs) 

H redifAmountErrO 
H reditAmountResO 

■ reditUnitErrO 

■ reditUnitResO 

■ ebitAmountErr() 
H ebitAmountResO 
JP ebitUnilErrO 

<<uses» "• ebitUnilResO 

irectCredtAmountErr() 
irectCredtAmountR. .. 
irectCredtUnitErr() 
irectCredtUnitResO 
irectDebit AmountE rrO 
irecf Debit AmountRe... 
irectDebit UnitEtrO 
irectDebit Un it Res() 
xtendLifeTimeErr^) 
X tendLifeTi meRes 
ateErrO 
ate Res 

eserveAm ount Err() 
eserveAmountResO 
eser\eUnitErr() 
RsertRllnitResQ 




(l..ri- 



essionEndedO 



pAppCharg ngManager 

(from cs) 

■sessionAbortedO 



Figure: Application Interfaces 

This class diagram shows the interfaces of the charging SCF. 
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«lnterface» 

IpService 
(from csapi) 



■setCallbackQ 
pisetCallbackWithSession. 



«lnterface» 
IpChargingManager 

(from cs) 



;reateChargingSessi. 



«lnterface» 

IpChargingSession 

(from cs) 



pbreditAmountReqO 

|*creditUnitReq() 

|*debitAmountReq() 

PdebitUnitReqO 

HdirectCreditAmountR.. 

^irectCreditUnitReqO 

l^directDebitAmountRe. 

i*directDebitUnitReq() 

B*extendLifeTimeReq() 

BgetAmountLeftQ 

^etLifeTimeLeftj) 

BigetUnitLeftO 

B*rateReq() 

B*release() 

Bj'eserveAmountReqO 

^J-eserv eUn i tReqO 



Figure: Service interfaces 
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7 The Service Interface Specifications 

7.1 Interface Specification Format 

This section defines the interfaces, methods and parameters that form a part of the API specification. The Unified 
Modelling Language (UML) is used to specify the interface classes. The general format of an interface specification is 
described below. 

7.1.1 Interface Class 

This shows a UML interface class description of the methods supported by that interface, and the relevant parameters 
and types. The Service and Framework interfaces for enterprise-based client applications are denoted by classes with 
name Ip<naine>. The callback interfaces to the applications are denoted by classes with name IpApp<name>. For 
the interfaces between a Service and the Framework, the Service interfaces are typically denoted by classes with name 
IpSvc<name>, while the Framework interfaces are denoted by classes with name IpFw<name> 

7.1.2 Method descriptions 

Each method (API method "call") is described. All methods in the API return a value of type TpResult, indicating, 
amongst other things, if the method invocation was sucessfully executed or not. 

Both synchronous and asynchronous methods are used in the API. Asynchronous methods are identified by a 'Req' 
suffix for a method request, and, if applicable, are served by asynchronous methods identified by either a 'Res' or 'Err' 
suffix for method results and errors, respectively. To handle responses and reports, the application or service developer 
must implement the relevant IpApp<name> or IpSvc<name> interfaces to provide the callback mechanism. 



7.1.3 Parameter descriptions 

Each method parameter and its possible values are described. Parameters described as 'in' represent those that must have 
a value when the method is called. Those described as 'out' are those that contain the return result of the method when 
the method returns. 

7.1.4 State Model 

If relevant, a state model is shown to illustrate the states of the objects that implement the described interface. 

7.2 Base Interface 

7.2.1 Interface Class Iplnterface 

All application, framework and service interfaces inherit from the following interface. This API Base Interface does not 
provide any additional methods. 



«lnterface» 
Iplnterface 
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7.3 Service Interfaces 
7.3.1 Overview 

The Service Interfaces provide the interfaces into the capabiHties of the underlying network - such as call control, user 
interaction, messaging, mobility and connectivity management. 

The interfaces that are implemented by the services are denoted as 'Service Interface'. The corresponding interfaces that 
must be implemented by the application (e.g. for API callbacks) are denoted as 'Application Interface'. 

7.4 Generic Service Interface 
7.4.1 Interface Class IpService 

Inherits from: Iplnterface 

AU service interfaces inherit from the following interface. 



«lnterface» 
IpService 



setCallback (applnterface : in IplnterfaceRef) : TpResult 

setCallbackWitinSessionlD (applnterface : in IplnterfaceRef, sessionID : in TpSessionID) : TpResult 



Method 
setCallback () 

This method specifies the reference address of the callback interface that a service uses to invoke methods on the 
application. It is not allowed to invoke this method on an interface that uses SessionlD's. 

Parameters 

applnterface : in IplnterfaceRef 

Specifies a reference to the application interface, which is used for callbacks 

Raises 
TpCoinmonExceptions 



Method 
setCallbackWithSessionID () 

This method specifies the reference address of the application's callback interface that a service uses for interactions 
associated with a specific session ID: e.g. a specific call, or call leg. It is not allowed to invoke this method on an 
interface that does not uses SessionlD's. 
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Parameters 

applnterface : in IpInterfaceRef 

Specifies a reference to the application interface, which is used for callbacks 

sessionID : in TpSessionID 

Specifies the session for which the service can invoke the application's callback interface. 

Raises 
TpCommonExceptions 



8 Charging Interface Classes 



The Charging SCF is used by applications to charge for the usage of the applications. The charged user can be the same 
user as that uses the application. It is also possible that another user will pay the charge. 



In the interfaces of the Charging SCF a "Request Number" is used when invoking operations that operate on the user's 
account (directly or indirectly via reservations) in order to make retries possible after application, service, or 
communication errors. A retry of these operations can be done by invoking the same operation with the same Request 
Number. 

In the callback to the application, the Request Number to be used for the next request operation is returned. This is the 
only Request Number besides the one in the last request operation that can be used. This mechanism ensures that an 
application retries an operation when it does not receive an answer. 

8.1 Interface Class IpChargingManager 

Inherits from: IpService. 

This interface is the 'service manager' interface for the Charging Service. The Charging manager interface provides 
management functions to the charging service. The application programmer can use this interface to start charging 
sessions. 



«lnterface» 
IpChargingManager 



createChargingSession (appChargingSession : in IpAppCinargingSessionRef, applicationDescription : in 
TpString, mercinantAccount : in TpMercinantAccountlD, user : in TpAddress, correlationID : in 
TpCorrelationID, cinargingSession : out TpCinargingSessionlDRef) : TpResult 



Method 
createChargingSession ( ) 

This method creates an instance of the IpChargingSession interface to handle the charging events related to the 
specified user and to the appUcation invoking this method. 
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Parameters 

appChargingSession : in IpAppChargingSessionRef 

Callback interface for the session in the application 

applicationDescription : in TpString 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user). 

merchantAccount : in TpMerchant Account ID 

Identifies the account of the party providing the application to be used. 

user : in TpAddress 

Specifies the user that is using the application. This may or may not be the user that will be charged. The Charging 
service will determine the charged user. When this method is invoked the Charging service shall determine if charging 
is allowed for this application for this subscriber. An exception shall be thrown if this type of charging is not allowed. 

correlationID : in TpCorrelationID 

This value can be used to correlate the charging to network activity. 

chargingSession : out TpChargingSessionlDRef 

Defines the session. 

Raises 

TpCommonExceptions, P_INVALID_USER, P_INVALID_ACCOUNT 

8.2 Interface Class IpAppChargingSession 

Inherits from: Iplnterface. 

This application interface must be implemented by the client application to handle callbacks from the 
IpChargingSession. 



«lnterface» 
IpAppChargingSession 



extendLifelimeRes (sessionID : in TpSessionID, SessionTimeLeft : in Tplnt32) : TpResult 

extendLifelimeErr (sessionID : in TpSessionID, error : in TpCinargingError) : TpResult 

creditAmountRes (sessionID : in TpSessionID, creditedAmount : in TpChargingPrice, reservedAmountLeft : 
in TpChargingPrice, requestNumberNextRequest : in Tplnt32) : TpResult 

creditAmountErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest : in 
Tplnt32) : TpResult 

debitAmountRes (sessionID : in TpSessionID, debitedAmount : in TpChargingPrice, reservedAmountLeft : 
in TpChargingPrice, requestNumberNextRequest : in Tplnt32) : TpResult 

debitAmountErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest : in 
Tplnt32) : TpResult 

reserveAmountRes (sessionID : in TpSessionID, reservedAmount : in TpChargingPrice, sessionTimeLeft : 
in Tplnt32, requestNumberNextRequest : in Tplnt32) : TpResult 

reserveAmountErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest : in 
Tplnt32) : TpResult 
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directCreditAmountRes (sessionID : in TpSessionID, creditedAmount : in TpCinargingPrice, 
requestNumberNextRequest : in Tplnt32) : TpResult 

directCreditAmountErr (sessionID : in TpSessionID, error : in TpCinarging Error, requestNumberNextRequest 
: in Tplnt32) : TpResult 

directDebitAmountRes (sessionID : in TpSessionID, debitedAmount : in TpChargingPrice, 
requestNumberNextRequest : in Tplnt32) : TpResult 

directDebitAmountErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest 
: in Tplnt32) : TpResult 

creditUnitRes (sessionID : in TpSessionID, creditedVolumes : in TpVolumeSet, reservedUnitsLeft : in 
TpVolumeSet, requestNumberNextRequest : in Tplnt32) : TpResult 

creditUnitErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest : in 
Tplnt32) : TpResult 

debitUnitRes (sessionID : in TpSessionID, debitedVolumes : in TpVolumeSet, reservedUnitsLeft : in 
TpVolumeSet, requestNumberNextRequest : in Tplnt32) : TpResult 

debitUnitErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest : in 
Tplnt32) : TpResult 

reserveUnitRes (sessionID : in TpSessionID, reservedUnits : in TpVolumeSet, sessionTimeLeft : in Tplnt32, 
requestNumberNextRequest : in Tplnt32) : TpResult 

sessionEnded (sessionID : in TpSessionID, report : in TpSessionEndedCause) : TpResult 

reserveUnitErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest : in 
Tplnt32) : TpResult 

rateRes (sessionID : in TpSessionID, rates : in TpPriceVolumeSet, validityTimeLeft : in TpDuration) : 
TpResult 

rateErr (sessionID : in TpSessionID, error : in TpChargingError) : TpResult 

directCreditUnitRes (sessionID : in TpSessionID, creditedVolumes : in TpVolumeSet, 
requestNumberNextRequest : in Tplnt32) : TpResult 

directCreditUnitErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest : in 
Tplnt32) : TpResult 

directDebitUnitRes (sessionID : in TpSessionID, debitedVolumes : in TpVolumeSet, 
requestNumberNextRequest : in Tplnt32) : TpResult 

directDebitUnitErr (sessionID : in TpSessionID, error : in TpChargingError, requestNumberNextRequest : in 
Tplnt32) : TpResult 



Method 
extendLifeTimeRes () 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

SessionTimeLeft : in Tplnt32 

Indicates the number of seconds that the session remains valid. 
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Method 

extendLif eTimeErr ( ) 

This method indicates that the corresponding request failed. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_NO_EXTEND 



Method 

credit Amount Res () 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

credit edAmount : in TpChargingPrice 

Indicates the credited amount. 

reservedAmountLeft : in TpChargingPrice 

The amount left of the reservation. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

creditAmountErr ( ) 

This method indicates that the corresponding request failed completely and that no money has been credited. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_CURRENCY. 
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requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

deb it Amount Res () 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

debitedAmount : in TpChargingPrice 

Indicates the debited amount. 

reservedAmountLeft : in TpChargingPrice 

The amount left of the reservation. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

debit Amount Err ( ) 

This method indicates that the corresponding request failed completely and that no money has been debited. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_CURRENCY 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

reserveAmountRes () 

This method indicates that the corresponding request was successful. 
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Parameters 

sessionID : in TpSessionID 

This is the same as the session ID returned in the request. 

reservedAmount : in TpChargingPrice 

The amount reserved. If there was already a pending reservation, the sum of that and the new reservation is given. 

sessionTimeLeft : in Tplnt32 

Indicates the number of seconds that the session and the reservation therein remains valid. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

reserveAmountErr ( ) 

This method indicates that the corresponding request failed. The reservation cannot be used. 

Parameters 

sessionID : in TpSessionID 

This is the same as the session ID returned in the request. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_PARAMETER, 
P_CHS_ERR_RESERVATION_LIMIT, P_CHS_ERR_CURRENCY, P_CHS_ERR_NO_EXTEND 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 
directCreditAmountRes () 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

credit edAmount : in TpChargingPrice 

Indicates the credited amount. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 
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Method 
directCreditAmountErr ( ) 

This method indicates that the corresponding request failed completely and that no money has been credited. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_PARAMETER, P_CHS_ERR_NO_CREDIT, 
P_CHS_ERR_CURRENCY 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

directDebitAmountRes ( ) 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

debitedAmount : in TpChargingPrice 

Indicates the debited amount. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 
directDebitAmountErr ( ) 

This method indicates that the corresponding request failed completely and that no money has been debited. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_PARAMETER, P_CHS_ERR_NO_DEBIT, 
P_CHS_ERR_CURRENCY 
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requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

creditUnitRes ( ) 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

creditedVolvimes : in TpVolumeSet 

Indicates the credited volumes of application usage. 

reservedUnitsLeft : in TpVolumeSet 

The volume of application usage left in the reservation. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

creditUnitErr ( ) 

This method indicates that the corresponding request failed completely and that no units have been credited. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_VOLUMES 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

debitUnitRes () 

This method indicates that the corresponding request was successful. 
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Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

debitedVolumes : in TpVolvimeSet 

Indicates the debited volumes of application usage. 

reservedUnitsLeft : in TpVolumeSet 

The volume of application usage left in the reservation. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

debitUnitErr ( ) 

This method indicates that the corresponding request failed completely and that no units have been debited. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_VOLUMES 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 
reserveUnitRes () 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the same as the session ID returned in the request. 

reservedUnits : in TpVolumeSet 

The volume of application usage reserved. If there was already a pending reservation, the sum of that and the new 
reservation is returned. E.g. a pending reservation of 25 charging units and a new reservation of 1000 octets and 10 
charging units will result in two Tp Volume elements for this parameter: 1000 octets and 35 charging units. 

sessionTimeLeft : in Tplnt32 

Indicates the number of seconds that the session and the reservation therein remains valid. 
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requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

sessionEnded ( ) 

This method indicates to the appHcation that the charging session has terminated in the charging server. The apphcation 
is expected to de-assign the charging session object after having received the sessionEnded. 

Parameters 

sessionID : in TpSessionID 

Specifies the charging sessionID. 

report : in TpSessionEndedCause 

Specifies the cause the charging session is terminated. 



Method 

reserveUnitErr ( ) 

This method indicates that the corresponding request failed. The reservation cannot be used. 

Parameters 

sessionID : in TpSessionID 

This is the same as the session ID returned in the request. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_PARAMETER, P_CHS_ERR_ VOLUMES, 
P_CHS_ERR_RESERVATION_LIMIT, P_CHS_ERR_NO_EXTEND 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 
rateRes () 

This method indicates that the corresponding request was successful. 



Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

rates : in TpPriceVolumeSet 

The applicable rates. 
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validityTimeLeft : in TpDuration 

Indicates the number of milli-seconds that this information remains valid. 



Method 

rateErr () 

This method indicates that the corresponding request failed. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_PARAMETER 



Method 
directCreditUnitRes () 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

creditedVolvimes : in TpVolumeSet 

Indicates the credited volumes of application usage. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

directCreditUnitErr 

This method indicates that the corresponding request failed completely and that no units have been credited. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_PARAMETER, P_CHS_ERR_NO_CREDIT, 
P_CHS_ERR_VOLUMES 
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requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 



Method 

directDebitUnitRes ( ) 

This method indicates that the corresponding request was successful. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

debitedVolumes : in TpVoliomeSet 

Indicates the debited volumes of application usage. 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 

Method 
directDebitUnitErr () 

This method indicates that the corresponding request failed completely and that no units have been debited. 

Parameters 

sessionID : in TpSessionID 

This is the ID of the session for which the operation was called. 

error : in TpChargingError 

Indicates the reason for failure. Possible errors are: P_CHS_ERR_PARAMETER, P_CHS_ERR_NO_DEBIT, 
P_CHS_ERR_VOLUMES 

requestNumberNextRequest : in Tplnt32 

This request number must be used in the next request (requiring a Request Number) for this session. 

8.3 Interface Class IpChargingSession 

Inherits from: IpService. 

The Charging Session interface provides operations to facilitate transactions between a merchant and a user. The 
application programmer can use this interface to debit or credit amounts and/or units towards a user, to create and 
extend the lifetime of a reservation and to get information about what is left of the reservation. 



«lnterface» 
IpChargingSession 



reserveAmountReq (sessionID : in TpSessionID, preferredAmount : in TpClnargingPrice, minimumAmount 
in TpCliargingPrice, applicationDescription : in TpApplicationDescription, requestNumber : in Tplnt32, 
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chargingParameters : in TpChargingParameterSet) : TpResult 

creditAmountReq (sessionID : in TpSessionID, applicationDescription : in TpApplicationDescription, amount 
: in TpCinargingPrice, closeReservation : in TpBoolean, requestNumber : in Tplnt32) : TpResult 

debitAmountReq (sessionID : in TpSessionID, applicationDescription : in TpApplicationDescription, amount : 
in TpChargingPrice, closeReservation : in TpBoolean, requestNumber : in Tplnt32) : TpResult 

getAmountLeft (sessionID : in TpSessionID, amountLeft : out TpChargingPriceRef) : TpResult 

release (sessionID : in TpSessionID, requestNumber : in Tplnt32) : TpResult 

extendLifeTimeReq (sessionID : in TpSessionID) : TpResult 

getLifeTimeLeft (sessionID : in TpSessionID, reservationTimeLeft : out Tplnt32Ref) : TpResult 

directCreditAmountReq (sessionID : in TpSessionID, applicationDescription : in TpApplicationDescription, 
chargingParameters : in TpChargingParameterSet, amount : in TpChargingPrice, requestNumber : in 
Tplnt32) : TpResult 

directDebitAmountReq (sessionID : in TpSessionID, applicationDescription : in TpApplicationDescription, 
chargingParameters : in TpChargingParameterSet, amount : in TpChargingPrice, requestNumber : in 
Tplnt32) : TpResult 

reserveUnitReq (sessionID : in TpSessionID, chargingParameters : in TpChargingParameterSet, volumes : 
in TpVolumeSet, applicationDescription : in TpApplicationDescription, requestNumber : in Tplnt32) : 
TpResult 

creditUnitReq (sessionID : in TpSessionID, applicationDescription : in TpApplicationDescription, volumes : 
in TpVolumeSet, closeReservation : in TpBoolean, requestNumber : in Tplnt32) : TpResult 

debitUnitReq (sessionID : in TpSessionID, applicationDescription : in TpApplicationDescription, volumes : in 
TpVolumeSet, closeReservation : in TpBoolean, requestNumber : in Tplnt32) : TpResult 

getUnitLeft (sessionID : in TpSessionID, volumesLeft : out TpVolumeSetRef) : TpResult 

rateReq (sessionID : in TpSessionID, chargingParameters : in TpChargingParameterSet) : TpResult 

directCreditUnitReq (sessionID : in TpSessionID, applicationDescription : in TpApplicationDescription, 
chargingParameters : in TpChargingParameterSet, volumes : in TpVolumeSet, requestNumber : in 
Tplnt32) : TpResult 

directDebitUnitReq (sessionID : in TpSessionID, applicationDescription : in TpApplicationDescription, 
chargingParameters : in TpChargingParameterSet, volumes : in TpVolumeSet, requestNumber : in 
Tplnt32) : TpResult 



Method 
reserveAmountReq ( ) 

This method is used when an application wants to reserve an amount of money for services to be delivered to a user. It 
is also possible to enlarge the existing amount reservation by invoking this method. If a reservation is extended, the 
lifetime of the reservation is re-initialized. 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

preferredAmount : in TpChargingPrice 

The amount of specified currency that the application wants to be reserved. 
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minimvunAmount : in TpChargingPrice 

The minimum amount that can be used by the apphcation if the preferred amount cannot be granted. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

request Number : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 

chargingParameters : in TpChargingParameterSet 

These parameters and their values specify to the charging service what was provided to the end user so that the charging 
service can determine the applicable tariff. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_AMOUNT, P_INVALID_CURREN 
CY, P_INVALID_REQUEST_NUMBER 



Method 

credit AmountReq ( ) 

This method credits an amount towards the reservation associated with the session. 

The amount left in the reservation will be increased by this amount. 

Each request to debit / credit an amount towards a reservation is handled separately. For example, two requests for a 
payment of EUR 1,- will give a total payment of EUR 2,-. 

A credit of EUR 1,- and a debit of EUR 1 will give a total payment of EUR 0,-. 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

amount : in TpChargingPrice 

The amount of specified currency to be credited towards the user. 

closeReservation : in TpBoolean 

If set to true, this parameter indicates that the remaining part of the reservation can be freed and the session can be 
closed. This may also mean addition of currency to the subscriber's account if more credits than debits have been made. 

requestNumber : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 
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Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_AMOUNT, P_INVALID_CURREN 
CY, P_INVALID_REQUEST_NUMBER 



Method 
debitAmountReq ( ) 

This method debits an amount from the reservation. 

The amount left in the reservation will be decreased by this amount. 

Each request to debit / credit an amount towards a reservation is handled separately. For example, two requests for a 
payment of EUR 1,- will give a total payment of EUR 2,-. 

A credit of EUR 1,- and a debit of EUR 1 will give a total payment of EUR 0,-. 

When a debit operation would exceed the limit of the reservation, the debit operation fails. 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

amount : in TpChargingPrice 

The amount of specified currency to be debited from the user. 

closeReservation : in TpBoolean 

If set to true, this parameter indicates that the reservation can be freed and the session can be closed. 

request Number : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_AMOUNT, P_INVALID_CURREN 
CY, P_INVALID_REQUEST_NUMBER 



Method 
getAmountLef t ( ) 

With this method an application can request the remaining amount of the reservation. 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 



£75/ 



3GPP TS 29.198-12 version 4.0.0 Release 4 



30 



ETSI TS 129 198-12 V4.0.0 (2001-06) 



amountLeft : out TpChargingPriceRef 

Gives the amount left in the reservation. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID 



Method 
release () 

This method releases the session, no operations can be done towards this session anymore (not even retries). Unused 
parts of a reservation are freed. 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

requestNumber : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_REQUEST_NUMBER 



Method 

extendLif eTimeReq ( ) 

With this method an application can request the lifetime of the reservation to be extended. If no reservation has been 
made on the charging session, this method raises an exception (P_TASK_REFUSED). 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID 



Method 
getLifeTimeLeft () 

With this method an application can request the remaining lifetime of the reservation. If no reservation has been made 
on the charging session, this method raises an exception (P_TASK_REFUSED). 
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Parameters 

sessionID : in TpSessionID 

The ID of the session. 

reservationTimeLeft : out TpInt32Ref 

Indicates the number of seconds that the session remains valid. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID 



Method 
directCreditAmountReq ( ) 

This method directly credits an amount towards the user. 

A possible reservation associated with this session is not influenced. 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

chargingParameters : in TpChargingParameterSet 

These parameters and their values specify to the charging service what was provided to the end user so that the charging 
service can determine the applicable tariff.. 

amount : in TpChargingPrice 

The amount of specified currency to be credited towards the user. 

request Number : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_AMOUNT, P_INVALID_CURREN 
CY, P_INVALID_REQUEST_NUMBER 



Method 
directDebitAmountReq ( ) 

This method directly debits an amount towards the user. 

A possible reservation associated with this session is not influenced. 
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Parameters 

sessionID : in TpSessionID 

The ID of the session. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

chargingParameters : in TpChargingParameterSet 

These parameters and their values specify to the charging service what was provided to the end user so that the charging 
service can determine the applicable tariff. 

amount : in TpChargingPrice 

The amount of specified currency to be debited from the user. 

requestNumber : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_AMOUNT, P_INVALID_CURREN 
CY, P_INVALID_REQUEST_NUMBER 



Method 
reserveUnitReq ( ) 

This method is used when an application wants to reserve volumes of application usage to be delivered to a user in the 
session. When using units it is assumed that the price setting for the units is handled by the network side services. It is 
also possible to enlarge the existing unit reservation by invoking this method. 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

chargingParameters : in TpChargingParameterSet 

These parameters and their values specify to the charging service what was provided to the end user so that the charging 
service can determine the applicable tariff.. 

volvimes : in TpVolumeSet 

Specifies the reserved volumes in different units, more specifically a sequence of data elements each containing the 
amount and applied unit. It is e.g. possible to make a reservation for 10000 octets and 5 charging units. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

requestNumber : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 
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Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_VOLUME , P_INVALID_REQUES 
T NUMBER 



Method 
creditUnitReq ( ) 

This method credits a volume of application usage towards the reservation. 

The volumes left in the reservation of this will be increased by this amount. 

Each request to debit / credit a volume towards a reservation is handled separately. For example, two requests for a 
payment for 10 kilobytes will give a total payment for 20 kilobytes 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

volvimes : in TpVolumeSet 

Specifies the credited volumes in different units, more specifically a sequence of data elements each containing the 
amount and applied unit. 

closeReservation : in TpBoolean 

If set to true, this parameter indicates that the reservation can be freed and the session can be closed. 

request Number : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_VOLUME , P_INVALID_REQUES 
T NUMBER 



Method 
debitUnitReq ( ) 

This method debits a volume of application usage from the reservation. 

The volumes left in the reservation will be decreased by this amount. 

Each request to debit / credit a volume towards a reservation is handled separately. For example, two requests for a 
payment for 10 kilobytes will give a total payment for 20 kilobytes. 

When a debit operation would exceed the limit of the reservation, the debit operation succeeds, and the debited volumes 
will be the rest of the volumes in the reservation. 
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Parameters 

sessionID : in TpSessionID 

The ID of the session. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

volvimes : in TpVolumeSet 

Specifies the charged volumes in different units, more specifically a sequence of data elements each containing the 
amount and applied unit. 

closeReservation : in TpBoolean 

If set to true, this parameter indicates that the reservation can be freed and the session can be closed. 

requestNumber : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_VOLUME , P_INVALID_REQUES 
T NUMBER 



Method 
getUnitLeftO 

With this method an application can request the remaining amount of the reservation. 

Parameters 

sessionID : in TpSessionID 

The ID of the session. 

volvimesLeft : out TpVolvimeSetRef 

Specifies the remaining volumes in different units, more specifically a sequence of data elements each containing the 
amount and applied unit. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID 



Method 
rateReq ( ) 

This method is used when the application wants to have an item rated by the charging service. The result can be used to 
present pricing information to the end user before the end user actually want to start using the service. 
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Parameters 

sessionID : in TpSessionID 

The ID of the session. 

chargingParameters : in TpChargingParameterSet 

These parameters and their values specify to the charging service what was provided to the end user so that the charging 
service can determine the applicable tariff.. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID 



Method 
directCreditUnitReq ( ) 

This method directly credits a volume of application usage towards the user. 

The volumes in a possible reservation associated with this session are not influenced. 

Parameters 

sessionID : in TpSessionID 

The ID of the reservation. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

chargingParameters : in TpChargingParameterSet 

These parameters and their values specify to the charging service what was provided to the end user so that the charging 
service can determine the applicable tariff.. 

volvimes : in TpVolumeSet 

Specifies the credited volumes in different units, more specifically a sequence of data elements each containing the 
amount and applied unit. 

request Number : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_VOLUME , P_INVALID_REQUES 
T NUMBER 



Method 
directDebitUnitReq ( ) 

This method directly credits a volume of application usage towards the user. 

The volumes in a possible reservation associated with this session are not influence. 
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Parameters 

sessionID : in TpSessionID 

The ID of the reservation. 

applicationDescription : in TpApplicationDescription 

Descriptive text for informational purposes (e.g. text presented on the bill and used in communication towards the user) 

chargingParameters : in TpChargingParameterSet 

These parameters and their values specify to the charging service what was provided to the end user so that the charging 
service can determine the applicable tariff. 

volvimes : in TpVolumeSet 

Specifies the charged volumes in different units, more specifically a sequence of data elements each containing the 
amount and applied unit. 

requestNumber : in Tplnt32 

Specifies the number given in the result of the previous operation on this session, or when creating the session. When 
no answer is received the same operation with the same parameters must be retried with the same requestNumber. 

Raises 

TpCommonExceptions , P_INVALID_SESSION_ID , P_INVALID_VOLUME , P_INVALID_REQUES 
T NUMBER 



8.4 Interface Class IpAppChargingManager 

Inherits from: Iplnterface. 

This interface is the manager application interface for the Charging Service. The Charging manager interface provides 
the application Charging Session Management functions to the charging service. 



«lnterface» 
IpAppChargingManager 



sessionAborted (sessionID : in TpSessionID) : TpResult 



Method 
sessionAborted ( ) 

This method indicates to the application that the charging session object (at the gateway) has aborted or terminated 
abnormally. No further communication will be possible between the charging session and application. 

Parameters 

sessionID : in TpSessionID 

Specifies the sessionID of the charging session that has aborted or terminated abnormally. 
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9 State Transition Diagrams 

9.1 State Transition Diagrams for IpChargingSession 
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Figure : Charging Session IHandling 

9.1 .1 Session Created State 

In this state the Charging Session is created. No reservations have been made. In this state, the applications have the 
possibility to perform direct debits and credits on the user's account and to request rating. 

9.1 .2 Amount Reserved State 

In this state a reservation for a certain maximum amount has been made. This reservation has succeeded and the 
application has the possibility to perform incremental debits/credits on this reserved amount until the Charging Session 
is released (either explicitly by the application or implicitly when the lifetime of the session has expired). The 
application can also extend the reservation and control its lifetime. 

9.1 .3 Volume Reserved State 

In this state a reservation for a certain maximum volume (kilobytes, emails, html-pages, etc) has been made. This 
reservation has succeeded and the application has the possibility to perform incremental debits/credits on this reserved 
volume until the Charging Session is released (either explicitly by the application or implicitly when the lifetime of the 
session has expired). The application can also extend the reservation and control its lifetime. 



10 



Data Definitions 



10.1 Charging Data Definitions 



This clause provides the Charging specific data definitions necessary to support the OSA interface specification. 

The present document is written using Hypertext link, to aid navigation through the data structures. Underlined text 
represents Hypertext links. 

The general format of a data definition specification is the following: 

• Data type, that shows the name of the data type. 

• Description, that describes the data type. 

• Tabular specification, that specifies the data types and values of the data type. 

• Example, if relevant, shown to illustrate the data type. 



TpApplicationDescription 

Defines a Sequence of Data Elements that specifies what is about to be charged. 



Sequence Element Name 


Sequence Element Type 


Text 


TpStrina 


App Information 


TpAppInformationSet 



TpAppInformationSet 

Defines a Numbered Set of Data Elements that further describe what is about to be charged. The data elements are of 
type TpAppInformation. 
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TpAppInformation 

Defines a Tagged Choice of Data Elements that comprise an individual application information. 





Tag Element Type 






TpAppInf ormationTvpe 






Tag Element Value 


Choice Element Type 


Choice Element Name 


P_APP_INF_TIMESTAMP 


TpDateAndTime 


Time St amp 



TpAppInf ormationType 

Defines the possible information items. 



1 Name 


Value 


Description ^^^^H 


^^^^^^■1 


P_APP_INF_TIMESTAMP 





The information item contains a timestamp. 



TpSessionEndedCause 

Defines the reason for which a charging session is released. 



1 Name 


Value 


Description 


1 


P_CHS_CAUSE__UNDEFINED 





Tlie reason of release isn't known, because no info was received from the network. 


P_CHS_CAUSE_TIMER_EXPIRED 


1 


The session life time has expired. 



TpMe r chant Ac c oun 1 1 D 

Defines a Sequence of Data Elements that defines the used service. 



Sequence Element Name 


Sequence Element Type 


MerchantID 


TpString 


Account ID 


Tplnt32 



TpCorrelationID 

Defines the Sequence of Data Elements that identify a correlation. 



1 Sequence Element Name 


Sequence Element Type 


CorrelationID 


TpSessionID 


CorrelationType 


TpCorrelationTvpe 



TpCorrelationType 

Defines the type of correlation. This type can be extended with operator specific items. 



Name 


Value 


Description 


P„CHS„CORRELATION_UNDEFINED 





Unknown correlation type. 


P_CH S_CORRE LAT I ON_VO ICE 


1 


Voice Call 


P_CH S_CORRE LAT I ON_D ATA 


2 


Data Session 


P_CH S_CORRE LAT I ON_MM 


3 


Multi Media Session 









TpChargingPrice 

Defines the Sequence of Data Elements that identify a price. 
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Sequence Element Name 


^^^ Sequence Element Type 


Currency 


TpString 


Amount 


TpAmount 


NOTE: Currencies as defined by ISO 421 7:1 995 [6]. 



Tp Amount 

Defines the Sequence of Data Elements that define an amount in integers as "Number * 10 '^ Exponent" (i.e. 
if Number = 6543 and Exponent = -2 then the amount is 65,43). This representation avoids unwanted rounding off. 



I Sequence Element Name ^^^m 


Sequence Element Type 


Number 


Tplnt32 


Exponent 


Tplnt32 



TpChargingParameterSet 

Defines a Numbered Set of Data Elements of TpChargingParameter 



TpChargingParameter 

Defines a Sequence of Data Elements that defines the used service. 



Sequence Element Name 


Sequence Element Type 


ParameterlD 


TpChareingParameterlD 


Par amete rvalue 


TpChargingParameterValue 



TpChargingParameter ID 

Defines the type of charging parameter. This type can be extended with operator specific items. 



Name 


Value 


Description 


P_CHS_PARAM_UNDEFINED 





Unknown parameter 


P_CHS_PARAM_ITEM 


1 


Parameter represents kind of service delivered to the end user 


P_CHS_PARAM_SUBTYPE 


2 


Parameter represents subtype / operation of service delivered to the end user 


P_CHS_PARAM_RESULT 


3 


Parameter represents the result of the service 









TpChargingParameterValue 

Defines the Taggeci Choice of Data Elements that identify a charging parameter. 





Tag Element Type 






TpCharginaParameterValueTvpe 






Tag Element Value 


Choice Element Type 


Choice Element Name 


P_CHS_PARAMETER_INT32 


Tplnt32 


IntValue 


P_CHS_PARAMETER_FLOAT 


TpFloat 


FloatValue 


P_CHS_PARAMETER_STRING 


TpString 


StringValue 


P_CHS_PARAMETER_BOOLEAN 


TpBoolean 


BooleanValue 



TpChargingParameterValueType 

Defines the type of charging parameter. 
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Name 


Value 


Description 


P_CHS_PARAMETER_INT32 





Parameter represented by a Tplnt32 


P_CHS_PARAMETER_FLOAT 


1 


Parameter represented by a TpFloat 


P_CHS_PARAMETER_STRING 


2 


Parameter represented by a TpString 


P_CHS_PARAMETER_BOOLEAN 


3 


Parameter represented by a TpBoolean 



TpVolumeSet 

Defines the Numbered Set of Data Elements that describes list Tp Volume . 

TpVolume 

Defines a volume. 



^^~ Sequence Element Name 


Sequence Element Type 


Amount 


TpAmount 


Unit 


TpUnitID 



TpUnitID 

Defines the unit that is used in a TpVolume . This type can be extended with operator specific items. 



Name 


Value 


Description 


P_CHS_UNIT_UNDEFINED 





Undefined 


P_CHS_UN I T_NUMBER 


1 


number of times / events 


P_CHS_UNIT_OCTETS 


2 


unit is octets 


P_CHS_UNIT_SECONDS 


3 


unit is seconds 


P_CHS_UNIT_MINUTES 


4 


unit is minutes 


P_CH S_UN I T_HOURS 


5 


unit is hours 


P_CHS_UNIT_DAYS 


6 


unit is days 









TpChargingSessionID 

Defines the Sequence of Data Elements that unambiguously specify the Charging Session object. 



[ Sequence Element Name 


Sequence Element 
Type 


^^^1 Sequence Element Description ^^^HII 


ChargingSessionRef erence 


IpChargingSessionRef 


This element specifies the interface reference for the charging session 
object. 


ChargingSessionID 


TpSessionID 


This element specifies the session ID for the charging session. 


RequestNumberFirstRequest 


Tplnt32 


This element specifies the request number to use for the next request. 



TpPriceVolumeSet 

Defines a Numbered Set of Data Elements of TpPrice Volume . 

TpPriceVolume 

Defines the Sequence of Data Elements that identify a price for a volume. 



Sequence Element Name 


Sequence Element Type 


Price 


TpCharainsPrice 


Volume 


TpVolume 
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TpChargingError 

Indicates the error that occurred. 



Name 


Value 


Description 


P_CHS_ERR_UNDEFINED 





Generic error 


P_CHS_ERR_ACCOUNT 


1 


Merchant account unknown 


P_CHS_ERR_USER 


2 


Unknown user 


P_CHS_ERR_PARAMETER 


3 


The set of charging parameters contains an unknown parameter, or a required parameter is 

missing. 


P_CHS_ERR_NO_DEBIT 


4 


For some reason the application is not allowed to get money from this user. 


P_CHS_ERR_NO_CREDIT 


5 


For some reason the application is not allowed to pay this user. 


P_CHS_ERR_VOLUMES 


6 


Required volumes are missing. 


P_CHS_ERR_CURRENCY 


7 


This cuiTency is not supported for this transaction. 


P_CHS_ERR_NO_EXTEND 


8 


Request to extend the hftetime of a reservation is rejected. 


P_CHS_ERR_RESERVATION_LIMIT 


9 


This amount or volume violates the bounds of the reservation 





1 1 Exception Classes 



The following are the list of exception classes, which are used in this interface of the API. 



, Name 


Description 


P_INVALID_ACCOUNT 


Invahd merchant account specified. 


P_INVALID_REQUEST_NUMBER 


Invalid request number specified. 


P_INVALID_USER 


hivalid user specified. 


P_INVALID_VOLUME 


hivalid volume specified. 



Each exception class contains the following structure: 



1 Structure Element Name 


Structure Element Type 


Structure Element Description 


extra In format ion 


TpString 


Carries extra information to help identify the source of the 
exception, e.g. a parameter name 
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Annex A (normative): 

OMG IDL Description of Charging SCF 

The OMG IDL representation of this interface specification is contained in a text file (cs.idl contained in archive 
2919812IDL.ZIP) which accompanies the present document. 
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Annex B (infonnative): 
Change history 


Change history 
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